-
Notifications
You must be signed in to change notification settings - Fork 3.7k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Enhance unnest support in decoupled mode #17550
base: master
Are you sure you want to change the base?
Enhance unnest support in decoupled mode #17550
Conversation
return makeIdentityMapping(input); | ||
} | ||
|
||
protected TrimResult dummyProject(int fieldCount, RelNode input, |
Check notice
Code scanning / CodeQL
Missing Override annotation
return result(input, mapping); | ||
} | ||
|
||
public TrimResult trimFields( |
Check notice
Code scanning / CodeQL
Deprecated method or constructor invocation Note test
CalciteTestBase.makeColumnExpression
sql/src/main/java/org/apache/druid/sql/calcite/planner/DruidRelFieldTrimmer.java
Fixed
Show fixed
Hide fixed
sql/src/main/java/org/apache/druid/sql/calcite/planner/DruidRelFieldTrimmer.java
Fixed
Show fixed
Hide fixed
…mer-unnestfieldtype
import java.util.List; | ||
import java.util.Set; | ||
|
||
public class DruidRelFieldTrimmer extends RelFieldTrimmer |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
A javadoc for this class would be really useful
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
added a few lines; main goal of the class is the same as RelFieldTrimmer
- so I've added a link to it in the apidoc as all of those also applies here
.columnTypes(ColumnType.LONG) | ||
.context(defaultScanQueryContext( | ||
queryContext, | ||
RowSignature.builder().add("v0", ColumnType.LONG).build() | ||
RowSignature.builder().add("__time", ColumnType.LONG).build() |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I did not understand why the column name changes here. I don't see any other change to the test
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
no columns are needed from the left hand side; but Calcite has some tweaks here and there to avoid relnodes with 0
columns.
This PR suppresses the introduction of a column with the 0
value by the Fieldtrimmer
but in one of the rules there is also an unconditional projection of the 1st columns
which causes this change.
We should be able to handle the case of empty columns - I wanted to dig into that more deeply ; as it seems like there are also some rule combinations which may lead to an empty column set...(but forgot the testcase)
I think that in general Calcite should be able to handle these things - and we should only make
corrections in the execution engine if it causes issues.
sql/src/test/java/org/apache/druid/sql/calcite/CalciteJoinQueryTest.java
Outdated
Show resolved
Hide resolved
@@ -92,7 +92,8 @@ enum Modes | |||
SORT_REMOVE_CONSTANT_KEYS_CONFLICT(DruidException.class, "not enough rules"), | |||
REQUIRE_TIME_CONDITION(CannotBuildQueryException.class, "requireTimeCondition is enabled"), | |||
UNNEST_INLINED(Exception.class, "Missing conversion is Uncollect"), | |||
UNNEST_RESULT_MISMATCH(AssertionError.class, "(Result count mismatch|column content mismatch)"); | |||
UNNEST_RESULT_MISMATCH(AssertionError.class, "(Result count mismatch|column content mismatch)"), | |||
RESULT_MISMATCH_NATIVE_UNNEST_INCORRECT_RESULTS(Throwable.class, "(Result count mismatch|column content mismatch|ARRAY)"); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Is this required? Won't it be covered by the previous one?
Add a test to ensure that CalciteJoinQuery can handle join queries with input ref conditions.
…ported - Modified the @NotYetSupported annotation to @NotYetSupported(Modes.UNNEST_PREDICATE_NOT_SUPPORTED) in CalciteArraysQueryTest.java. - Updated the @DecoupledTestConfig annotation to @DecoupledTestConfig(ignoreExpectedQueriesReason = IgnoreQueriesReason.PREDICATE_NOT_SUPPORTED) in CalciteArraysQueryTest.java. - These changes reflect the need to support unnest predicates in the future.
…mer-unnestfieldtype
LogicalCorrelate
andUnnest
-s